package com.company.offer;

/**
 * 输入一个英文句子，翻转句子中单词的顺序，但单词内字符的顺序不变。为简单起见，标点符号和普通字母一样处理。例如输入字符串"I am a student. "，则输出"student. a am I"。
 * <p>
 *  
 * <p>
 * 示例 1：
 * <p>
 * 输入: "the sky is blue"
 * 输出: "blue is sky the"
 * 示例 2：
 * <p>
 * 输入: "  hello world!  "
 * 输出: "world! hello"
 * 解释: 输入字符串可以在前面或者后面包含多余的空格，但是反转后的字符不能包括。
 * 示例 3：
 * <p>
 * 输入: "a good   example"
 * 输出: "example good a"
 * 解释: 如果两个单词间有多余的空格，将反转后单词间的空格减少到只含一个。
 * <p>
 * 来源：力扣（LeetCode）
 * 链接：https://leetcode-cn.com/problems/fan-zhuan-dan-ci-shun-xu-lcof
 * 著作权归领扣网络所有。商业转载请联系官方授权，非商业转载请注明出处。
 */
public class Offer58_I {
    public String reverseWords(String s) {
        //去首尾空格
        String word = s.trim();
        int j = word.length() - 1, i = j;
        StringBuilder builder = new StringBuilder();
        while (i >= 0) {
            while (i >= 0 && word.charAt(i) != ' ') {
                i--;
            }
            builder.append(word.substring(i + 1, j + 1) + " ");
            while (i >= 0 && word.charAt(i) == ' ') {
                i--;
            }
            j = i;
        }
        return builder.toString().trim();
    }

    public static void main(String[] args) {
        Offer58_I offer58_i=new Offer58_I();
        String s=offer58_i.reverseWords("a good   example");
        System.out.println(s);
    }
}
